



## REPLACEMENT CLAIM PAGES

### WHAT IS CLAIMED IS:

1. A method of controlling the execution of instructions within a pipelined processor, comprising:

5 providing an instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said words comprising a jump instruction having at least one user-configurable mode associated therewith;

10 assigning one of a plurality of values to at least one of said data bits of said at least one jump instruction; and

controlling the execution of at least one subsequent instruction within said pipeline based on said one assigned value of said at least one data bit when said at least one jump instruction is decoded.

2. The method of Claim 1, wherein the act of assigning comprises:

15 identifying a plurality of data bits within said at least one jump instruction; and assigning one of two discrete values to each of said data bits, the combination of said two discrete values representing at least three jump delay slot modes within said processor.

3. The method of Claim 2, wherein the act of controlling the execution based on said discrete values comprises selecting at least one mode from the group comprising:

20 (i) executing said at least one subsequent instruction under all circumstances;

(ii) executing said at least one subsequent instruction only if a jump occurs; and (iii) stalling the pipeline or inserting a bubble into the pipeline if a jump occurs.

4. The method of Claim 3, wherein said at least one jump instruction comprises a conditional branch instruction.

25 5. The method of Claim 1, wherein the act of controlling the execution based on said one assigned value comprises:

(i) executing said at least one subsequent instruction under all circumstances;

(ii) executing said at least one subsequent instruction only if a jump occurs; and stalling the pipeline or inserting a bubble into the pipeline if a jump occurs.

30 6.-13. [Cancelled]

Application Serial No.: 09/523,877  
Filed: March 13, 2000

14. A digital processor comprising:

a processor core having a multistage instruction pipeline, said core being adapted to decode and execute an instruction set comprising a plurality of instruction words;  
a data interface between said processor core and an information storage device;

5 and

an instruction set comprising a plurality of instruction words, at least one of said instruction words being a user-configurable jump instruction containing data defining a plurality of jump delay slot modes, said plurality of modes controlling the execution of instructions within said instruction pipeline of said processor core in response to said at least 10 one jump instruction word within said instruction set.

15. The processor of Claim 14, wherein said plurality of jump delay slot modes comprises at least the following modes:

- (i) executing a subsequent instruction within said pipeline under all circumstances;
- (ii) executing a subsequent instruction within said pipeline only if jumping occurs;
- 15 and
- (iii) stalling the pipeline if jumping occurs.

16. The processor of Claim 14, wherein said at least one jump instruction comprises a conditional branch instruction having an associated logical condition, the execution of a jump to the address within said information storage device specified by said at least one conditional 20 branch instruction being determined by said logical condition.

17. A digital processor having at least one pipeline and an associated data storage device, wherein the execution of instructions within said at least one pipeline is controlled by the method comprising:

25 storing an instruction set within said data storage device, said instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said instruction words comprising a user-configurable branch instruction directing branching to a first address within said data storage device;

assigning one of a plurality of values to each of said data bits of said at least one branch instruction;

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

decoding said at least one branch instruction including said one values; determining whether to execute an instruction within said pipeline in a stage preceding that of said at least one branch instruction based at least in part on said one values; and branching to said first address based on said at least one branching instruction.

5 18. The processor of Claim 17, wherein said data bits comprise binary (base 2) data.

19. The method of Claim 17, wherein said at least one pipeline comprises at least a three stage instruction pipeline comprising instruction fetch, decode, and execute stages.

20. A method of controlling program operation of a multi-stage pipelined digital processor, comprising:

10 storing an instruction set within said data storage device, said instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said instruction words comprising a branch instruction directing branching to a first address within said data storage device based on a first parameter;

defining a plurality of jump delay slot modes comprising;

15 (i) executing a subsequent instruction under all circumstances;  
(ii) executing a subsequent instruction only if jumping occurs;  
(iii) stalling the pipeline for one cycle if jumping occurs; and  
(iv) stalling the pipeline for two or more cycles if jumping occurs;

20 assigning at least one of said plurality of jump modes to at least two of said data bits of said at least one branch instruction;

decoding said at least one branch instruction including said at least two data bits; and controlling said pipeline based at least in part on said at least two data bits and said first 25 parameter.

21-22.[Cancelled]

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

23. A digital processor comprising:

processing means having a multistage data pipeline, said processing means being adapted to decode and execute an instruction set comprising a plurality of instruction words;

5 means for storing data;

data interface means for transferring data between said processing means and said means for storing data; and

10 an instruction set comprising a plurality of instruction words, at least one of said instruction words being a user-configurable jump instruction containing data defining a plurality of jump control means, said plurality of jump control means controlling the execution of instructions within said data pipeline of said processing means in response to said at least one jump instruction word within said instruction set.

24. [Cancelled]

25. The method of Claim 1, wherein at least one of said plurality of instruction words comprises an op-code and a plurality of fields, each of said fields comprising a plurality of bits, said at least one instruction word being encoded according to the method comprising:

associating a first of said fields with a first data source;

associating a second of said fields with a second data source; and

20 performing a logical operation using said first and second data sources as operands, said logical operation being specified by said op-code.

26. The method of Claim 1, further comprising generating a long immediate constant using a single word instruction according to the method comprising:

providing an instruction word having an op-code and at least one short immediate value associated therewith, said at least one short immediate value comprising a plurality of bits;

25 selecting a portion of said plurality of bits of said at least one short immediate value;

shifting all of said bits of said at least one short immediate value using said op-code and only said portion of bits to produce a shifted immediate value; and

storing said shifted immediate value in a register.

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

27. The method of Claim 25, wherein said plurality of instruction words further comprises at least one instruction word having an op-code and at least one short immediate value associated therewith, said at least one short immediate value comprising a plurality of bits, said at least one instruction word with short immediate value being used to generate a long immediate constant according to the method comprising:

selecting a portion of said plurality of bits of said at least one short immediate value;  
shifting all of said bits of said at least one short immediate value using said op-code and only said portion of bits to produce a shifted immediate value; and  
storing said shifted immediate value in a register.

10 28. The method of Claim 27, wherein said at least one instruction word having a plurality of fields and said at least one instruction word having a short immediate value comprise the same instruction word(s).

29. The digital processor of Claim 14, wherein said wherein at least one of said plurality of instruction words comprises an op-code and a plurality of fields, each of said fields comprising a plurality of bits, said at least one instruction word being encoded by:

associating a first of said fields with a first data source;  
associating a second of said fields with a second data source; and  
performing a logical operation using said first and second data sources as operands, said logical operation being specified by said op-code.

20 30. The digital processor of Claim 14, wherein said processor is further adapted to generate a long immediate constant using a single word instruction by:

providing an instruction word having an op-code and at least one short immediate value associated therewith, said at least one short immediate value comprising a plurality of bits;  
selecting a portion of said plurality of bits of said at least one short immediate value;  
shifting all of said bits of said at least one short immediate value using said op-code and only said portion of bits to produce a shifted immediate value; and  
storing said shifted immediate value in a register.

31. The digital processor of Claim 29, wherein said plurality of instruction words further comprises at least one instruction word having an op-code and at least one short

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

immediate value associated therewith, said at least one short immediate value comprising a plurality of bits, said at least one instruction word with short immediate value being used to generate a long immediate constant according to the method comprising:

5           selecting a portion of said plurality of bits of said at least one short immediate value;  
          shifting all of said bits of said at least one short immediate value using said op-code and  
          only said portion of bits to produce a shifted immediate value; and  
          storing said shifted immediate value in a register.

32.       The digital processor of Claim 31, wherein said at least one instruction word  
having a plurality of fields and said at least one instruction word having a short immediate  
10       value comprise the same instruction word(s).

33.       A method of controlling the execution of instructions within a user-configured  
pipelined processor, comprising:  
          providing an instruction set comprising a plurality of instruction words, each of said  
instruction words comprising a plurality of data bits, at least one of said words comprising a  
15       branch instruction having at least one user-configurable mode and a plurality of other modes  
adapted for controlling the execution of at least one subsequent instruction;

20       assigning one of a plurality of values to at least one of said data bits of said at least one  
branch instruction; and

          controlling the execution of at least one subsequent instruction within said pipeline  
25       based on said one assigned value of said at least one data bit when said at least one branch  
instruction is decoded.

34.       A method of controlling the execution of instructions within a pipelined  
processor, comprising:  
          providing an instruction set comprising a plurality of instruction words, each of said  
instruction words comprising a plurality of data bits, at least one of said words comprising a  
25       jump instruction;

          assigning one of a plurality of values to first and second of said data bits of said at least  
one jump instruction, said first and second bits adapted to define four discrete jump modes; and

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

controlling the execution of at least one subsequent instruction within said pipeline based on said assigned values of said first and second data bits when said at least one jump instruction is decoded.

35. A method of controlling the execution of instructions within a pipelined  
5 processor, comprising:

providing an instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said words comprising a jump instruction;

10 assigning one of a plurality of values to first and second of said data bits of said at least one jump instruction, said first and second bits adapted to define four discrete jump modes, said four discrete jump modes including one user-defined jump mode; and

controlling the execution of at least one subsequent instruction within said pipeline based on said assigned values of said first and second data bits when said at least one jump instruction is decoded.

15 36. A digital processor having at least one pipeline and an associated data storage device containing at least a portion of an instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said words comprising a jump instruction, wherein the execution of instructions within said at least one pipeline is controlled by (i) the assignment of one of a plurality of values to first and second of said data bits of said at least one jump instruction, said first and second bits adapted to define four discrete jump modes; and (ii) the execution of at least one subsequent instruction within said pipeline based on said assigned values of said first and second data bits, when said at least one jump instruction is decoded.

20 25 37. An extensible pipelined digital processor having an instruction set comprising a plurality of basecase instructions and at least one extension instruction, at least one of said basecase and extension instructions comprising a branch instruction having at least one user-configurable mode and a plurality of other modes controlling the execution of at least one instruction in a delay slot following said branch instruction within said pipeline.

**Application Serial No.:** 09/523,877  
**Filed:** March 13, 2000

38. An extensible pipelined digital processor having an instruction set comprising a plurality of basecase instructions and at least one extension instruction, at least one of said basecase and extension instructions comprising a branch instruction including two data bits defining four discrete modes controlling the execution of at least one instruction in a delay slot following said branch instruction within said pipeline.

5 39. An extensible pipelined digital processor having an instruction set, said processor comprising:

a basecase processor core configuration including a base instruction set; and  
at least one user-configured extension instruction within said instruction set, said at least  
10 one extension instruction comprising a branch instruction having at least one user-defined mode  
and a plurality of other modes controlling the execution of at least one instruction in a delay slot  
following said branch instruction within said pipeline.

15 40. An extensible pipelined digital processor having basecase and extension instruction sets, at least one instruction within said basecase set comprising a branch instruction having at least four discrete modes for controlling the execution of at least one instruction in a delay slot following said branch instruction within said pipeline, said processor comprising:

a basecase processor core configuration including said base instruction set; and  
at least one user-customized extension instruction within said instruction set.

20 41. A digital processor having at least one pipeline and an associated data storage device containing at least a portion of an instruction set comprising a plurality of instruction words, each of said instruction words comprising a plurality of data bits, at least one of said words comprising a branch instruction, wherein the execution of instructions within said at least one pipeline is controlled by (i) the assignment of one of a plurality of values to at least first, second, and third of said data bits of said at least one branch instruction, said first, second, and  
25 third bits adapted to define at least four discrete branch modes; and (ii) the execution of at least one subsequent instruction within said pipeline based on said assigned values of said first, second, and third data bits, when said at least one branch instruction is decoded.

42. The digital processor of Claim 41, wherein first and second of said at least four branch modes implement one- and two-cycle stalls within said pipeline, respectively.

**Application Serial No.:** **09/523,877**  
**Filed:** **March 13, 2000**

43. The digital processor of Claim 41, wherein at least one of said at least four branch modes comprises a user-configurable mode.